<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
    <th:block th:include="common/include :: header('养修服务单项列表')"/>
</head>
<body class="gray-bg">
<div class="container-div">
    <div class="row">
        <div class="col-sm-12 search-collapse">
            <form id="customer-form">
                <div class="select-list">
                    <ul>
                        <li>
                            名称：<input type="text" name="name"/>
                        </li>
                        <li>
                            是否套餐：
                            <select name="carPackage" th:with="items=${@dict.getType('si_car_package')}">
                                <option value="">所有</option>
                                <option th:each="item : ${items}" th:text="${item.label}"
                                        th:value="${item.value}"></option>
                            </select>
                        </li>
                        <li>
                            服务分类：
                            <select name="serviceCatalog" th:with="items=${@dict.getType('si_service_catalog')}">
                                <option value="">所有</option>
                                <option th:each="item : ${items}" th:text="${item.label}"
                                        th:value="${item.value}"></option>
                            </select>
                        </li>
                        <li>
                            审核状态：
                            <select name="auditStatus" th:with="items=${@dict.getType('si_audit_status')}">
                                <option value="">所有</option>
                                <option th:each="item : ${items}" th:text="${item.label}"
                                        th:value="${item.value}"></option>
                            </select>
                        </li>
                        <li>
                            上架状态：
                            <select name="saleStatus" th:with="items=${@dict.getType('si_sale_status')}">
                                <option value="">所有</option>
                                <option th:each="item : ${items}" th:text="${item.label}"
                                        th:value="${item.value}"></option>
                            </select>
                        </li>
                        <li>
                            <a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i
                                    class="fa fa-search"></i>&nbsp;搜索</a>
                            <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i
                                    class="fa fa-refresh"></i>&nbsp;重置</a>
                        </li>
                    </ul>
                </div>
            </form>
        </div>

        <div class="btn-group-sm" id="toolbar" role="group">
            <a class="btn btn-success" onclick="$.operate.add()" shiro:hasPermission="business:serviceItem:add">
                <i class="fa fa-plus"></i> 添加
            </a>
            <a class="btn btn-danger" onclick="$.operate.removeAll()" shiro:hasPermission="business:serviceItem:removeAll">
                <i class="fa fa-remove"></i> 删除
            </a>
            <a class="btn btn-primary disabled auditBtn" onclick="startAudit()"
               shiro:hasPermission="business:serviceItem:startAudit">
                <i class="fa fa-download"></i> 发起审核
            </a>
        </div>

        <div class="col-sm-12 select-table table-striped">
            <table id="bootstrap-table"></table>
        </div>
    </div>
</div>
<th:block th:include="common/include :: footer"/>
<script th:inline="javascript">
    var carPackageData = [[${@dict.getType('si_car_package')}]];
    var serviceCatalogData = [[${@dict.getType('si_service_catalog')}]];
    var auditStatusData = [[${@dict.getType('si_audit_status')}]];
    var saleStatusData = [[${@dict.getType('si_sale_status')}]];

    var editFlag = [[${@permission.hasPermi('business:serviceItem:edit')}]];
    var saleOnFlag = [[${@permission.hasPermi('business:serviceItem:saleOn')}]];
    var saleOffFlag = [[${@permission.hasPermi('business:serviceItem:saleOff')}]];

    var prefix = ctx + "/business/serviceItem";
    $(function () {
        var options = {
            url: prefix + "/query",
            createUrl: prefix + "/addPage",
            updateUrl: prefix + "/editPage?id={id}",
            removeUrl: prefix + "/remove",
            modalName: "养修服务单项",
            columns: [
                {
                    checkbox: true
                },
                {
                    field: 'id',
                    title: '编号',
                    visible: false
                },
                {
                    field: 'name',
                    title: '服务项名称'
                },
                {
                    field: 'originalPrice',
                    title: '服务项原价'
                },
                {
                    field: 'discountPrice',
                    title: '服务项折扣价'
                },
                {
                    field: 'carPackage',
                    title: '是否套餐',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(carPackageData, value);
                    }
                },
                {
                    field: 'info',
                    title: '备注信息'
                },
                {
                    field: 'serviceCatalog',
                    title: '服务分类',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(serviceCatalogData, value);
                    }
                },
                {
                    field: 'auditStatus',
                    title: '审核状态',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(auditStatusData, value);
                    }
                },
                {
                    field: 'saleStatus',
                    title: '上架状态',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(saleStatusData, value);
                    }
                },
                {
                    title: '操作',
                    align: 'center',
                    formatter: function (value, row, index) {
                        var actions = [];
                        var editFlagTemp = editFlag;
                        var saleOnFlagTemp = saleOnFlag;
                        var saleOffFlagTemp = saleOffFlag;
                        /* 编辑按钮 */
                        // 已上架或审核状态为审核中，则不能点击
                        if (row.saleStatus === 1 || row.auditStatus === 1) {
                            editFlagTemp += 'disabled';
                        }
                        actions.push('<a class="btn btn-success btn-xs ' + editFlagTemp + '" href="javascript:void(0)" ' +
                            'onclick="$.operate.edit(\'' + row.id + '\')"><i class="fa fa-edit"></i>编辑</a> ');
                        /* 上下架按钮 */
                        // 显示下架按钮
                        if (row.saleStatus === 1) {
                            actions.push('<a class="btn btn-danger btn-xs ' + saleOnFlagTemp + '" href="javascript:void(0)" ' +
                                'onclick="saleOff(\'' + row.id + '\')"><i class="fa fa-edit"></i>下架</a> ');
                        } else {
                            // 显示上架按钮
                            // 是套餐，并且审核没有通过，则不能点击
                            /*if (row.carPackage === 1 && row.auditStatus !== 2) {
                                saleOffFlagTemp += 'disabled';
                            }*/
                            saleOffFlagTemp += row.carPackage === 1 && row.auditStatus !== 2 ? 'disabled' : '';
                            actions.push('<a class="btn btn-info btn-xs ' + saleOffFlagTemp + '" href="javascript:void(0)" ' +
                                'onclick="saleOn(\'' + row.id + '\')"><i class="fa fa-edit"></i>上架</a> ');
                        }
                        return actions.join('');
                    }
                }
            ]
        };
        $.table.init(options);
        $("#bootstrap-table").on("check.bs.table uncheck.bs.table check-all.bs.table uncheck-all.bs.table load-success.bs.table", function () {
            //下架才能进行修改
            var rows = $.table.selectColumns("carPackage");     // 获取选择的行的carPackage，组成数组并进行去重
            let $auditBtn = $(".auditBtn");
            // 若去重数组中的长度等于1并且元素等于1，则表示选中的行都为套餐
            // 若去重数组中的长度等于1但元素不等于1，则表示选中的行都为非套餐
            // 若去重数组（[0, 1]）的长度不等于1，则表示选中的行含有非套餐
            if (rows.length === 1 && rows[0] === 1) {
                // 获取选中的审核状态的值组成的去重数组
                let auditStatus = $.table.selectColumns("auditStatus");
                for (let i = 0; i < auditStatus.length; i++) {
                    // 判断当前元素是否为审核中或审核完成
                    if (auditStatus[i] === 1 || auditStatus[i] === 2) {
                        // 使按钮不能点击
                        $auditBtn.addClass("disabled");
                        return;
                    }
                }
                $auditBtn.removeClass("disabled");
            }
        });
    });
    function saleOn(id) {
        $.modal.confirm("确认需要上架此服务项吗?", function () {
            $.operate.submit(prefix + "/saleOn?id=" + id, "post");
        })
    }
    function saleOff(id) {
        $.modal.confirm("确认需要下架此服务项吗?", function () {
            $.operate.submit(prefix + "/saleOff?id=" + id, "post");
        })
    }
    function startAudit() {
        let rowIds = $.table.selectColumns("id");
        $.modal.open("发起审核", prefix + "/auditPage?id=" + rowIds[0]);
    }
</script>
</body>
</html>